package com.zhong.gulimall.coupon;

import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;


/**
 * 1、如何使用nacos作为配置中心统一管理配置
 * 	1）引入依赖
 * 	<dependency>
 *      <groupId>com.alibaba.cloud</groupId>
 *      <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
 *  </dependency>
 * 	2）创建一个bootstrap.properties
 * 		spring.application.name=gulimall-coupon
 *  	spring.cloud.nacos.config.server-addr=127.0.0.1:8848
 *  3）需要给配置中心默认添加一个 DataID 为 gulimall-coupon.properties。默认规则，应用名.properties
 *  4) 给应用名.properties添加任意配置
 *  5）动态获取配置
 *  	@RefreshScope：动态刷新配置
 * 		@Value(${配置项的名})：获取到配置
 * 		如果配置中心和当前配置文件中都配置了相同的项，优先使用配置中心的项
 * 2、细节
 * 	1）、命名空间： 配置隔离
 * 		默认：public(保留空间)  默认新增的所有配置都在public空间。
 * 		1、开发、测试、生产：利用命名空间来做环境隔离。
 * 			注意：在bootstrap.properties：配置上，需要哪个命名空间下的配置
 * 			spring.cloud.nacos.config.namespace=b3ff8983-8c45-4c95-a7b9-5a9bc397b6c3
 * 		2、每一个微服务之间隔离配置，每一个微服务都创建自己的命名空间，只加载自己命名空间下的所有配置
 *
 * 	2）、配置集：所有的配置的集合
 *
 * 	3）、配置集ID：类似于文件名
 * 		DataID
 * 	4）、配置分组：
 * 		默认所有的配置集都属于DEFAULT_GROUP
 * 		1111，618，1212
 * 每个微服务创建自己的命名空间，使用配置分组来区分环境：dev，test，prod
 * 3、同时加载多个配置集
 * 	1)、微服务任何配置信息，任何配置文件都可以放在配置中心
 * 	2）、只需要在bootstrap.properties说明加载配置中心中哪些配置文件即可
 * 	3）、@Value，@ConfigurationProperties... 以前spring boot任何方法从配置文件中获取值的方法，都能使用
 * 		配置中心有的优先使用配置中心的
 */

//@MapperScan("com.zhong.gulimall.coupon.dao")
@EnableDiscoveryClient  // 开启服务注册与服务发现
@SpringBootApplication
public class GulimallCouponApplication {

	public static void main(String[] args) {
		SpringApplication.run(GulimallCouponApplication.class, args);
	}

}
